home *** CD-ROM | disk | FTP | other *** search
/ Turnbull China Bikeride / Turnbull China Bikeride - Disc 2.iso / STUTTGART / LANG / C / LIB / UNIXLIB37B / !UnixLib37 / src / unix / c / fcntl < prev    next >
Text File  |  1996-11-09  |  2KB  |  97 lines

  1. /****************************************************************************
  2.  *
  3.  * $Source: /unixb/home/unixlib/source/unixlib37/src/unix/c/RCS/fcntl,v $
  4.  * $Date: 1996/10/30 21:59:01 $
  5.  * $Revision: 1.2 $
  6.  * $State: Rel $
  7.  * $Author: unixlib $
  8.  *
  9.  * $Log: fcntl,v $
  10.  * Revision 1.2  1996/10/30 21:59:01  unixlib
  11.  * Massive changes made by Nick Burret and Peter Burwood.
  12.  *
  13.  * Revision 1.1  1996/04/19 21:35:27  simon
  14.  * Initial revision
  15.  *
  16.  ***************************************************************************/
  17.  
  18. static const char rcs_id[] = "$Id: fcntl,v 1.2 1996/10/30 21:59:01 unixlib Rel $";
  19.  
  20. #include <errno.h>
  21. #include <fcntl.h>
  22. #include <stdarg.h>
  23. #include <unistd.h>
  24. #include <sys/unix.h>
  25.  
  26. int
  27. fcntl (int fd, int cmd, ...)
  28. {
  29.   va_list ap;
  30.   register struct file *f;
  31.   int arg;
  32.  
  33.   va_start (ap, cmd);
  34.  
  35.   if (BADF (fd))
  36.     {
  37.       errno = EBADF;
  38.       va_end (ap);
  39.       return (-1);
  40.     }
  41.  
  42.   f = __u->file + fd;
  43.  
  44.   switch (cmd)
  45.     {
  46.     case F_DUPFD:
  47.       {
  48.     register struct file *_f;
  49.     arg = va_arg (ap, int);
  50.  
  51.     _f = __u->file + arg;
  52.     while (arg < MAXFD && _f->dup)
  53.       arg++, _f++;
  54.     if (arg >= MAXFD)
  55.       {
  56.         errno = EMFILE;
  57.             va_end (ap);
  58.         return (-1);
  59.       }
  60.       }
  61.       va_end (ap);
  62.       return (dup2 (fd, arg));
  63.       break;
  64.     case F_GETFD:
  65.       va_end (ap);
  66.       return ((f->oflag & O_EXECCL) ? 1 : 0);
  67.       break;
  68.     case F_SETFD:
  69.         arg = va_arg (ap, int);
  70.  
  71.         f->oflag = (f->oflag & (~O_EXECCL)) | \
  72.       ((arg & 1) ? O_EXECCL : 0);
  73.         va_end (ap);
  74.     return (0);
  75.       break;
  76.     case F_GETFL:
  77.       va_end (ap);
  78.       return (f->oflag);
  79.       break;
  80.     case F_SETFL:
  81.         arg = va_arg (ap, int);
  82.  
  83.         f->oflag = (f->oflag & ~(O_APPEND | O_NDELAY)) | \
  84.       (arg & (O_APPEND | O_NDELAY));
  85.     va_end (ap);
  86.         return (0);
  87.       break;
  88.     default:
  89.       errno = EINVAL;
  90.       va_end (ap);
  91.       return (-1);
  92.       break;
  93.     }
  94.   va_end (ap);
  95.   return -1;
  96. }
  97.